.card {
  position: relative;
  width: 268px;
  font-family: var(--font-cards);
}

.card__link {
  // Растягиваем ссылку на всю карточку
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.card__photo {
  margin-top: 50px;
  height: 240px;
  background-color: #fafafa;
  border-radius: 20px 20px 0 0;
  text-align: center;
}

.card__img {
  margin-top: -50px;
}

.card__desc {
  display: flex;
  flex-direction: column;
  gap: 6px;
  height: 202px;
  padding: 14px 22px 28px;
  background-color: rgb(255, 255, 255);
  border-radius: 0 0 20px 20px;
}

.card__category {
  // Поднимаем ссылку над общей ссылкой
  position: relative;
  z-index: 3;
  font-size: 16px;
  line-height: 20px;
  color: var(--text-muted);
}

.card__title {
  font-weight: 600;
  font-size: 21px;
  line-height: 26px;
  text-transform: capitalize;
  color: var(--text-card-dark-blue);
}

.card__rating {
  display: flex;
  align-items: center;
  gap: 2px;
}

.card__rating img {
  height: 18.28px;
}

.card__footer {
  // Чтобы контент не растягивал блок при увеличении строчек выше, этот блок прижимаем к низу
  margin-top: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.card__price {
  display: flex;
  align-items: flex-start;
  gap: 3px;
  font-weight: 600;
  font-size: 21px;
  color: var(--text-card-dark-blue);

  &::before {
    content: attr(data-value);
    font-size: 15px;
  }
}

.card__btn {
  // Поднимаем кнопку над общей ссылкой
  position: relative;
  z-index: 3;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background-color: var(--ui-dark-blue);
  font-size: 0;
  transition: opacity 0.2s ease-in;

  &:hover {
    opacity: 0.8;
  }
}